编程之美-将帅问题


   编程之美也是本好书,今天早上看了将帅问题,太经典了,让我联想到了编程珠玑的第
章,都是利用位来存储,来运算。  题目:把将帅符合要求的所有位置表示出来。  条件:只能使用一个8位的变量。  思路:对将帅两重循环所有位置,将%3相同的去掉,取剩下的位置。  本题主要侧重对于位运算的理解:位运算,位字段,位存储。  
#include <stdio.h>

#define HALF_BITS_LENGTH 4
#define FULLMASK 255 
#define LMASK (FULLMASK<<HALF_BITS_LENGTH) 
#define RMASK (FULLMASK>>HALF_BITS_LENGTH)
#define RSET(b,n) (b=((LMASK&b)|(n)))
#define LSET(b,n) (b=((RMASK&b)|((n)<<HALF_BITS_LENGTH)))
#define RGET(b) (RMASK&b)
#define LGET(b) ((LMASK&b)>>HALF_BITS_LENGTH)
#define GRIDW 3

//使用位段
struct {
	unsigned char a:4;
	unsigned char b:4;
}i;

int main()
{
//位段输出
	for(i.a=1;i.a<=9;i.a++)
		for(i.b=1;i.b<=9;i.b++)
			if(i.a%3!=i.b%3)
				printf("A=%d,B=%d\n",i.a,i.b);
//如果j=81到73,j/9:表示商为8
//j%9:对应的余数取1到9
//也即是每一个商对应9个余数,类似与两重遍历
	char j=81;
	while(j--)
	{
		if(j/9 %3 == j%9 %3)
			continue;
//		printf("A=%d,B=%d\n",j/9+1,j%9+1);
	}
//最基本的两重循环,将符合条件的输出
	unsigned char b;
	for(LSET(b,1);LGET(b)<=GRIDW * GRIDW;LSET(b,(LGET(b)+1)))
		for(RSET(b,1);RGET(b)<=GRIDW * GRIDW;RSET(b,(RGET(b)+1)))
			if(LGET(b)%GRIDW!=RGET(b)%GRIDW)
//				printf("A=%d,B=%d\n",LGET(b),RGET(b));
	return 0;
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值